<template>
    <div class="tool-logger">
        <span>
            <span>{{ t('response') }}</span>
            <span style="width: 200px;">
                <el-switch v-model="showRawJson" inline-prompt active-text="JSON" inactive-text="Text"
                    style="margin-left: 10px; width: 200px;"
                    :inactive-action-style="'backgroundColor: var(--sidebar)'" />
            </span>
        </span>
        <el-scrollbar height="500px">
            <div class="output-content" contenteditable="false">

                <!-- TODO: 更加稳定，现在通过下面这个来判断上一次执行结果是否成功 -->
                <div v-if="typeof tabStorage.lastToolCallResponse === 'string'" class="error-tool-call">
                    <span>
                        {{ tabStorage.lastToolCallResponse }}
                    </span>
                </div>

                <div v-else>
                    <!-- 展示原本的信息 -->
                    <template v-if="!showRawJson">
                        {{tabStorage.lastToolCallResponse?.content.map(c => c.text).join('\n')}}
                    </template>

                    <!-- 展示 json -->
                    <template v-else>
                        <json-render :json="tabStorage.lastToolCallResponse"/>
                    </template>
                </div>

            </div>
        </el-scrollbar>
    </div>
</template>

<script setup lang="ts">
import { defineComponent, defineProps, computed, ref } from 'vue';
import { useI18n } from 'vue-i18n';
import { tabs } from '../panel';
import type { ToolStorage } from './tools';
import JsonRender from '@/components/json-render/index.vue';

defineComponent({ name: 'tool-logger' });
const { t } = useI18n();

const props = defineProps({
    tabId: {
        type: Number,
        required: true
    }
});

const tab = tabs.content[props.tabId];
const tabStorage = tab.storage as ToolStorage;

const showRawJson = ref(false);

</script>

<style>
.tool-logger {
    border-radius: .5em;
    background-color: var(--background);
    padding: 10px;
}

.tool-logger .el-switch__core {
    border: 1px solid var(--main-color) !important;
    width: 60px !important;
}

.tool-logger .el-switch .el-switch__action {
    background-color: var(--main-color);
}

.tool-logger .el-switch.is-checked .el-switch__action {
    background-color: var(--sidebar);
}

.tool-logger>span:first-child {
    margin-bottom: 5px;
    display: flex;
    align-items: center;
}

.tool-logger .output-content {
    border-radius: .5em;
    padding: 15px;
    min-height: 450px;
    height: fit-content;
    font-family: var(--code-font-family);
    white-space: pre-wrap;
    word-break: break-all;
    user-select: text;
    cursor: text;
    font-size: 15px;
    line-height: 1.5;
    background-color: var(--sidebar);
}

.error-tool-call {
    background-color: rgba(245, 108, 108, 0.5);
    padding: 5px 9px;
    border-radius: .5em;
}
</style>